⚠️ Unpublished: This item is from a solution that is not yet published on Azure Marketplace or not installed in Content Hub.
Browse: 🏠 · Solutions · Connectors · Methods · Tables · Content · Parsers · ASIM Parsers · ASIM Products · Logic Apps · 📊
| Attribute | Value |
|---|---|
| Connector ID | CyjaxIOCAPI |
| Publisher | Cyjax |
| Used in Solutions | Cyjax |
| Collection Method | Azure Function (TI Upload API) |
| Connector Definition Files | CyjaxIOC_API_FunctionApp.json |
| Ingestion API | STIX 2.1 Upload Indicators API — Connector code references STIX 2.1 Upload Indicators API endpoint (matched 'api.ti.sentinel.azure.com') |
The Cyjax Threat Intelligence IOC data connector provides the capability to ingest Indicators of Compromise (IOCs) from the Cyjax API v2 into Microsoft Sentinel as STIX 2.1 Threat Intelligence indicators. The connector fetches IOCs including IPs, domains, URLs, file hashes, emails, and hostnames, enriches them with GeoIP, ASN, and sighting data, and uploads them to the Microsoft Sentinel Threat Intelligence platform via the Upload Indicator API.
The connector supports:
Automated IOC collection with configurable schedule
IOC enrichment with GeoIP, ASN, and sighting data
STIX 2.1 indicator mapping with TLP markings
Incremental fetching with checkpoint management
This connector ingests data into the following tables:
| Table | Selection Criteria | Transformations | Ingestion API | Lake-Only |
|---|---|---|---|---|
ThreatIntelIndicators |
SourceSystem == "Cyjax-IOCs" |
✓ | ✓ | ✗ |
ThreatIntelObjects |
✓ | ✓ | ? |
💡 Tip: Tables with Ingestion API support allow data ingestion via the Azure Monitor Data Collector API, which also enables custom transformations during ingestion.
Resource Provider Permissions:
Custom Permissions:
⚠️ Note: These instructions were automatically generated from the connector's user interface definition file using AI and may not be fully accurate. Please verify all configuration steps in the Microsoft Sentinel portal.
1. Resource Group
You need to have a resource group created with a subscription you are going to use.
2. Functions App
You need to have an Azure App registered for this connector to use:
NOTE: This connector uses Azure Functions to connect to the Cyjax API v2 to pull IOC indicators into Microsoft Sentinel. This might result in additional data ingestion costs. Check the Azure Functions pricing page for details.
STEP 1 - App Registration steps for the Application in Microsoft Entra ID
This integration requires an App registration in the Azure portal. Follow the steps in this section to create a new application in Microsoft Entra ID:
Reference link: https://learn.microsoft.com/azure/active-directory/develop/quickstart-register-app
STEP 2 - Add a client secret for application in Microsoft Entra ID
Sometimes called an application password, a client secret is a string value required for the execution of the Cyjax IOC Data Connector. Follow the steps in this section to create a new Client Secret:
Reference link: https://learn.microsoft.com/azure/active-directory/develop/quickstart-register-app#add-a-client-secret
STEP 3 - Assign Microsoft Sentinel Contributor Role
Assign the Microsoft Sentinel Contributor role to the App Registration to allow it to upload threat intelligence indicators:
STEP 4 - Obtain Cyjax API Credentials
Contact Cyjax to obtain your API v2 access token (Bearer Token). This token is used to authenticate requests to the Cyjax IOC and enrichment endpoints.
STEP 5 - Deploy the Cyjax IOC Connector
IMPORTANT: Before deploying the Cyjax IOC connector, have the Cyjax API access token, Azure App Registration credentials (Client ID, Client Secret, Tenant ID), and Workspace ID readily available.
WorkspaceIdNote: The value above is dynamically provided when these instructions are presented within Microsoft Sentinel.
8. Option 1 - Azure Resource Manager (ARM) Template
Use this method for automated deployment of the Cyjax IOC Data Connector.
Click the Deploy to Azure button below.
Select the preferred Subscription, Resource Group and Region.
Enter the below information:
a. FunctionName - Enter a unique Function App name (max 11 characters)
b. Location - The location for data collection rules and endpoints deployment
c. WorkspaceID - Enter the Log Analytics Workspace ID
d. AzureClientID - Enter Azure Client ID from your App Registration
e. AzureClientSecret - Enter Azure Client Secret from your App Registration
f. AzureTenantID - Enter Azure Tenant ID
g. CyjaxBaseURL - Enter Cyjax API v2 Base URL (default: https://api.cymon.co/v2)
h. CyjaxAccessToken - Enter Cyjax API Bearer Token
i. LookbackDays - Number of days to look back on first run (default: 1)
j. EnableEnrichment - Set to true to enrich IOCs with GeoIP, ASN, and sighting data. Set to false to skip enrichment and reduce API calls and execution time (default: true)
k. IOCQuery - Optional free-text search query to filter IOCs from the Cyjax API (e.g. a keyword, threat actor, or campaign name). Leave empty to fetch all available IOCs
l. IndicatorType - Filter IOCs by type. Enter comma-separated values (e.g., URL,Domain,IPv4). Supported types: URL, Domain, IPv4, IPv6, Hostname, Email, FileHash-SHA1, FileHash-SHA256, FileHash-MD5, FileHash-SSDEEP. Leave empty to fetch all types
m. Schedule - Enter a valid Quartz Cron-Expression (default: every 10 minutes)
n. LogLevel - Set the log level (default: Info)
o. AppInsightsWorkspaceResourceID - Enter the Application Insights Workspace Resource ID
Mark the checkbox labeled I agree to the terms and conditions stated above.
Click Purchase to deploy.
9. Option 2 - Manual Deployment of Azure Functions
Use the following step-by-step instructions to deploy the Cyjax IOC data connector manually with Azure Functions (Deployment via Visual Studio Code).
1. Deploy a Function App
NOTE: You will need to prepare VS code for Azure function development.
Download the Azure Function App file. Extract archive to your local development computer.
Start VS Code. Choose File in the main menu and select Open Folder.
Select the top level folder from extracted files.
Choose the Azure icon in the Activity bar, then in the Azure: Functions area, choose the Deploy to function app button. If you aren't already signed in, choose the Azure icon in the Activity bar, then in the Azure: Functions area, choose Sign in to Azure If you're already signed in, go to the next step.
Provide the following information at the prompts:
a. Select folder: Choose a folder from your workspace or browse to one that contains your function app.
b. Select Subscription: Choose the subscription to use.
c. Select Create new Function App in Azure (Don't choose the Advanced option)
d. Enter a globally unique name for the function app: Type a name that is valid in a URL path. The name you type is validated to make sure that it's unique in Azure Functions. (e.g. CYJAXXXXXX).
e. Select a runtime: Choose Python 3.12
f. Select a location for new resources. For better performance and lower costs choose the same region where Microsoft Sentinel is located.
Deployment will begin. A notification is displayed after your function app is created and the deployment package is applied.
Go to Azure Portal for the Function App configuration.
2. Configure the Function App
In the Function App, select the Function App Name and select Configuration.
In the Application settings tab, select + New application setting.
Add each of the following application settings individually, with their respective values (case-sensitive):
WorkspaceID - Your Log Analytics Workspace ID
AzureClientID - Azure Client ID from your App Registration
AzureClientSecret - Azure Client Secret from your App Registration
AzureTenantID - Your Azure Tenant ID
CyjaxBaseURL - Cyjax API v2 Base URL (default: https://api.cymon.co/v2)
CyjaxAccessToken - Your Cyjax API Bearer Token
LookbackDays - Number of days to look back on first run (default: 1)
EnableEnrichment - Set to true to enrich IOCs with GeoIP, ASN, and sighting data. Set to false to skip enrichment and reduce API calls and execution time (default: true)
IOCQuery - Optional free-text search query to filter IOCs from the Cyjax API (e.g. a keyword, threat actor, or campaign name). Leave empty to fetch all available IOCs (optional)
IndicatorType - Filter IOCs by type. Enter comma-separated values (e.g., URL,Domain,IPv4). Supported types: URL, Domain, IPv4, IPv6, Hostname, Email, FileHash-SHA1, FileHash-SHA256, FileHash-MD5, FileHash-SSDEEP. Leave empty to fetch all types (optional)
Schedule - Quartz Cron-Expression (default: every 10 minutes)
LogLevel - Log level (default: Info)
AppInsightsWorkspaceResourceID - Application Insights Workspace Resource ID (optional)
logAnalyticsUri (optional) - Use logAnalyticsUri to override the log analytics API endpoint for dedicated cloud. For example, for public cloud, leave the value empty; for Azure GovUS cloud environment, specify the value in the following format: https://<CustomerId>.ods.opinsights.azure.us.
Once all application settings have been entered, click Save.
📄 Source: [Cyjax\Data Connectors\README.md](https://github.com/Azure/Azure-Sentinel/blob/master/Solutions/Cyjax\Data Connectors\README.md)
This directory contains the Cyjax IOC (Indicators of Compromise) Data Connector for Microsoft Sentinel, which enables ingestion of threat intelligence indicators from the Cyjax API v2 into Microsoft Sentinel.
The Cyjax IOC Data Connector provides the capability to:
CyjaxIOC_API_FunctionApp.json - Microsoft Sentinel data connector definition fileazuredeploy_Connector_CyjaxIOC_AzureFunction.json - ARM template for automated deploymentCyjaxIOCIngestion/ - Azure Function source code for the connectorSharedCode/ - Shared utility code and librarieshost.json - Azure Functions host configurationrequirements.txt - Python dependencies for the Azure Functiontrue to enrich IOCs with GeoIP, ASN, and sighting data. Set to false to skip enrichment and reduce API calls and execution time (default: true)WorkspaceID: Your Log Analytics Workspace IDAzureClientID: Azure Client ID from App RegistrationAzureClientSecret: Azure Client Secret from App RegistrationAzureTenantID: Your Azure Tenant IDCyjaxBaseURL: Cyjax API v2 Base URLCyjaxAccessToken: Your Cyjax API Bearer TokenLookbackDays: Number of days to look back (default: 1)ENABLE_ENRICHMENT: Set to true to enrich IOCs with GeoIP, ASN, and sighting data. Set to false to skip enrichment (default: true)IOC_QUERY: Optional free-text search query to filter IOCs (e.g. keyword, threat actor, campaign name). Leave empty for no filter (optional)Indicator_Type: Filter IOCs by type. Enter comma-separated values (e.g., URL,Domain,IPv4). Supported types: URL, Domain, IPv4, IPv6, Hostname, Email, FileHash-SHA1, FileHash-SHA256, FileHash-MD5, FileHash-SSDEEP. Leave empty to fetch all types (optional)Schedule: Quartz Cron-ExpressionLogLevel: Log level (Info/Debug/Error/Warning)AppInsightsWorkspaceResourceID: Application Insights Workspace Resource ID (optional)logAnalyticsUri: Log Analytics API endpoint override (optional)Contact Cyjax to obtain your API v2 access token (Bearer Token)
The connector ingests data into the following table:
Browse: 🏠 · Solutions · Connectors · Methods · Tables · Content · Parsers · ASIM Parsers · ASIM Products · Logic Apps · 📊